<!doctype html>
<script src="../../../resources/testharness.js"></script>
<script src="../../../resources/testharnessreport.js"></script>
<script src="../../assert_selection.js"></script>
<script>
selection_test(
  '<div contenteditable dir="ltr">|Lorem <span style="direction: rtl">ipsum dolor sit</span> amet</div>',
  selection => selection.modify('extend', 'left', 'character'),
  '<div contenteditable dir="ltr">|Lorem <span style="direction: rtl">ipsum dolor sit</span> amet</div>',
  '1-0 ltr left character');

selection_test(
  '<div contenteditable dir="ltr">L|orem <span style="direction: rtl">ipsum dolor sit</span> amet</div>',
  selection => selection.modify('extend', 'left', 'character'),
  '<div contenteditable dir="ltr">|L^orem <span style="direction: rtl">ipsum dolor sit</span> amet</div>',
  '1-1 ltr left character');

selection_test(
  '<div contenteditable dir="ltr">Lo|rem <span style="direction: rtl">ipsum dolor sit</span> amet</div>',
  selection => selection.modify('extend', 'left', 'character'),
  '<div contenteditable dir="ltr">L|o^rem <span style="direction: rtl">ipsum dolor sit</span> amet</div>',
  '1-2 ltr left character');

selection_test(
  '<div contenteditable dir="ltr">Lor|em <span style="direction: rtl">ipsum dolor sit</span> amet</div>',
  selection => selection.modify('extend', 'left', 'character'),
  '<div contenteditable dir="ltr">Lo|r^em <span style="direction: rtl">ipsum dolor sit</span> amet</div>',
  '1-3 ltr left character');

selection_test(
  '<div contenteditable dir="ltr">Lore|m <span style="direction: rtl">ipsum dolor sit</span> amet</div>',
  selection => selection.modify('extend', 'left', 'character'),
  '<div contenteditable dir="ltr">Lor|e^m <span style="direction: rtl">ipsum dolor sit</span> amet</div>',
  '1-4 ltr left character');

selection_test(
  '<div contenteditable dir="ltr">Lorem| <span style="direction: rtl">ipsum dolor sit</span> amet</div>',
  selection => selection.modify('extend', 'left', 'character'),
  '<div contenteditable dir="ltr">Lore|m^ <span style="direction: rtl">ipsum dolor sit</span> amet</div>',
  '1-5 ltr left character');

selection_test(
  '<div contenteditable dir="ltr">Lorem <span style="direction: rtl">|ipsum dolor sit</span> amet</div>',
  selection => selection.modify('extend', 'left', 'character'),
  '<div contenteditable dir="ltr">Lorem| ^<span style="direction: rtl">ipsum dolor sit</span> amet</div>',
  '1-6 ltr left character');

selection_test(
  '<div contenteditable dir="ltr">Lorem <span style="direction: rtl">i|psum dolor sit</span> amet</div>',
  selection => selection.modify('extend', 'left', 'character'),
  '<div contenteditable dir="ltr">Lorem <span style="direction: rtl">|i^psum dolor sit</span> amet</div>',
  '1-7 ltr left character');

selection_test(
  '<div contenteditable dir="ltr">Lorem <span style="direction: rtl">ip|sum dolor sit</span> amet</div>',
  selection => selection.modify('extend', 'left', 'character'),
  '<div contenteditable dir="ltr">Lorem <span style="direction: rtl">i|p^sum dolor sit</span> amet</div>',
  '1-8 ltr left character');

selection_test(
  '<div contenteditable dir="ltr">Lorem <span style="direction: rtl">ips|um dolor sit</span> amet</div>',
  selection => selection.modify('extend', 'left', 'character'),
  '<div contenteditable dir="ltr">Lorem <span style="direction: rtl">ip|s^um dolor sit</span> amet</div>',
  '1-9 ltr left character');

selection_test(
  '<div contenteditable dir="ltr">Lorem <span style="direction: rtl">ipsu|m dolor sit</span> amet</div>',
  selection => selection.modify('extend', 'left', 'character'),
  '<div contenteditable dir="ltr">Lorem <span style="direction: rtl">ips|u^m dolor sit</span> amet</div>',
  '1-10 ltr left character');

selection_test(
  '<div contenteditable dir="ltr">Lorem <span style="direction: rtl">ipsum| dolor sit</span> amet</div>',
  selection => selection.modify('extend', 'left', 'character'),
  '<div contenteditable dir="ltr">Lorem <span style="direction: rtl">ipsu|m^ dolor sit</span> amet</div>',
  '1-11 ltr left character');

selection_test(
  '<div contenteditable dir="ltr">Lorem <span style="direction: rtl">ipsum |dolor sit</span> amet</div>',
  selection => selection.modify('extend', 'left', 'character'),
  '<div contenteditable dir="ltr">Lorem <span style="direction: rtl">ipsum| ^dolor sit</span> amet</div>',
  '1-12 ltr left character');

selection_test(
  '<div contenteditable dir="ltr">Lorem <span style="direction: rtl">ipsum d|olor sit</span> amet</div>',
  selection => selection.modify('extend', 'left', 'character'),
  '<div contenteditable dir="ltr">Lorem <span style="direction: rtl">ipsum |d^olor sit</span> amet</div>',
  '1-13 ltr left character');

selection_test(
  '<div contenteditable dir="ltr">Lorem <span style="direction: rtl">ipsum do|lor sit</span> amet</div>',
  selection => selection.modify('extend', 'left', 'character'),
  '<div contenteditable dir="ltr">Lorem <span style="direction: rtl">ipsum d|o^lor sit</span> amet</div>',
  '1-14 ltr left character');

selection_test(
  '<div contenteditable dir="ltr">Lorem <span style="direction: rtl">ipsum dol|or sit</span> amet</div>',
  selection => selection.modify('extend', 'left', 'character'),
  '<div contenteditable dir="ltr">Lorem <span style="direction: rtl">ipsum do|l^or sit</span> amet</div>',
  '1-15 ltr left character');

selection_test(
  '<div contenteditable dir="ltr">Lorem <span style="direction: rtl">ipsum dolo|r sit</span> amet</div>',
  selection => selection.modify('extend', 'left', 'character'),
  '<div contenteditable dir="ltr">Lorem <span style="direction: rtl">ipsum dol|o^r sit</span> amet</div>',
  '1-16 ltr left character');

selection_test(
  '<div contenteditable dir="ltr">Lorem <span style="direction: rtl">ipsum dolor| sit</span> amet</div>',
  selection => selection.modify('extend', 'left', 'character'),
  '<div contenteditable dir="ltr">Lorem <span style="direction: rtl">ipsum dolo|r^ sit</span> amet</div>',
  '1-17 ltr left character');

selection_test(
  '<div contenteditable dir="ltr">Lorem <span style="direction: rtl">ipsum dolor |sit</span> amet</div>',
  selection => selection.modify('extend', 'left', 'character'),
  '<div contenteditable dir="ltr">Lorem <span style="direction: rtl">ipsum dolor| ^sit</span> amet</div>',
  '1-18 ltr left character');

selection_test(
  '<div contenteditable dir="ltr">Lorem <span style="direction: rtl">ipsum dolor s|it</span> amet</div>',
  selection => selection.modify('extend', 'left', 'character'),
  '<div contenteditable dir="ltr">Lorem <span style="direction: rtl">ipsum dolor |s^it</span> amet</div>',
  '1-19 ltr left character');

selection_test(
  '<div contenteditable dir="ltr">Lorem <span style="direction: rtl">ipsum dolor si|t</span> amet</div>',
  selection => selection.modify('extend', 'left', 'character'),
  '<div contenteditable dir="ltr">Lorem <span style="direction: rtl">ipsum dolor s|i^t</span> amet</div>',
  '1-20 ltr left character');

selection_test(
  '<div contenteditable dir="ltr">Lorem <span style="direction: rtl">ipsum dolor sit</span>| amet</div>',
  selection => selection.modify('extend', 'left', 'character'),
  '<div contenteditable dir="ltr">Lorem <span style="direction: rtl">ipsum dolor si|t^</span> amet</div>',
  '1-21 ltr left character');

selection_test(
  '<div contenteditable dir="ltr">Lorem <span style="direction: rtl">ipsum dolor sit</span> |amet</div>',
  selection => selection.modify('extend', 'left', 'character'),
  '<div contenteditable dir="ltr">Lorem <span style="direction: rtl">ipsum dolor sit</span>| ^amet</div>',
  '1-22 ltr left character');

selection_test(
  '<div contenteditable dir="ltr">Lorem <span style="direction: rtl">ipsum dolor sit</span> a|met</div>',
  selection => selection.modify('extend', 'left', 'character'),
  '<div contenteditable dir="ltr">Lorem <span style="direction: rtl">ipsum dolor sit</span> |a^met</div>',
  '1-23 ltr left character');

selection_test(
  '<div contenteditable dir="ltr">Lorem <span style="direction: rtl">ipsum dolor sit</span> am|et</div>',
  selection => selection.modify('extend', 'left', 'character'),
  '<div contenteditable dir="ltr">Lorem <span style="direction: rtl">ipsum dolor sit</span> a|m^et</div>',
  '1-24 ltr left character');

selection_test(
  '<div contenteditable dir="ltr">Lorem <span style="direction: rtl">ipsum dolor sit</span> ame|t</div>',
  selection => selection.modify('extend', 'left', 'character'),
  '<div contenteditable dir="ltr">Lorem <span style="direction: rtl">ipsum dolor sit</span> am|e^t</div>',
  '1-25 ltr left character');

selection_test(
  '<div contenteditable dir="ltr">Lorem <span style="direction: rtl">ipsum dolor sit</span> amet|</div>',
  selection => selection.modify('extend', 'left', 'character'),
  '<div contenteditable dir="ltr">Lorem <span style="direction: rtl">ipsum dolor sit</span> ame|t^</div>',
  '1-26 ltr left character');
</script>
